<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  
  <meta http-equiv="X-UA-Compatible" content="IE=edge" >
  <title>iOS团队编程规范 | Grx Blog</title>
  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
  <meta name="description" content="iOS团队编程规范需求是暂时的，只有变化才是永恒的，面向变化编程，而不是面向需求编程。不要过分追求技巧，降低程序的可读性。简洁的代码可以让bug无处藏身。要写出明显没有bug的代码，而不是没有明显bug的代码。先把眼前的问题解决掉，解决好，再考虑将来的扩展问题。">
<meta property="og:type" content="article">
<meta property="og:title" content="iOS团队编程规范">
<meta property="og:url" content="http://yoursite.com/2018/08/15/iOS团队编程规范/index.html">
<meta property="og:site_name" content="Grx Blog">
<meta property="og:description" content="iOS团队编程规范需求是暂时的，只有变化才是永恒的，面向变化编程，而不是面向需求编程。不要过分追求技巧，降低程序的可读性。简洁的代码可以让bug无处藏身。要写出明显没有bug的代码，而不是没有明显bug的代码。先把眼前的问题解决掉，解决好，再考虑将来的扩展问题。">
<meta property="og:updated_time" content="2018-08-17T08:13:24.948Z">
<meta name="twitter:card" content="summary">
<meta name="twitter:title" content="iOS团队编程规范">
<meta name="twitter:description" content="iOS团队编程规范需求是暂时的，只有变化才是永恒的，面向变化编程，而不是面向需求编程。不要过分追求技巧，降低程序的可读性。简洁的代码可以让bug无处藏身。要写出明显没有bug的代码，而不是没有明显bug的代码。先把眼前的问题解决掉，解决好，再考虑将来的扩展问题。">
  
    <link rel="alternative" href="/atom.xml" title="Grx Blog" type="application/atom+xml">
  
  
    <link rel="icon" href="/favicon.png">
  
  <link rel="stylesheet" href="/css/style.css">
</head>

<body>
  <div id="container">
    <div class="left-col">
    <div class="overlay"></div>
<div class="intrude-less">
	<header id="header" class="inner">
		<a href="/" class="profilepic">
			
			<img lazy-src="/img/rufei.jpg" class="js-avatar">
			
		</a>

		<hgroup>
		  <h1 class="header-author"><a href="/">Grx</a></h1>
		</hgroup>

		
		<p class="header-subtitle">自我管理，知识管理，时间管理，阅读，语音写作，思维导图</p>
		

		
			<div class="switch-btn">
				<div class="icon">
					<div class="icon-ctn">
						<div class="icon-wrap icon-house" data-idx="0">
							<div class="birdhouse"></div>
							<div class="birdhouse_holes"></div>
						</div>
						<div class="icon-wrap icon-ribbon hide" data-idx="1">
							<div class="ribbon"></div>
						</div>
						
						<div class="icon-wrap icon-link hide" data-idx="2">
							<div class="loopback_l"></div>
							<div class="loopback_r"></div>
						</div>
						
						
						<div class="icon-wrap icon-me hide" data-idx="3">
							<div class="user"></div>
							<div class="shoulder"></div>
						</div>
						
					</div>
					
				</div>
				<div class="tips-box hide">
					<div class="tips-arrow"></div>
					<ul class="tips-inner">
						<li>菜单</li>
						<li>标签</li>
						
						<li>友情链接</li>
						
						
						<li>关于我</li>
						
					</ul>
				</div>
			</div>
		

		<div class="switch-area">
			<div class="switch-wrap">
				<section class="switch-part switch-part1">
					<nav class="header-menu">
						<ul>
						
							<li><a href="/">主页</a></li>
				        
							<li><a href="/tags/life">随笔</a></li>
				        
							<li><a href="/archives">所有文章</a></li>
				        
						</ul>
					</nav>
					<nav class="header-nav">
						<div class="social">
							
								<a class="github" target="_blank" href="https://github.com/ruixiaoguo" title="github">github</a>
					        
								<a class="weibo" target="_blank" href="https://weibo.com/u/3984935859?refer_flag=1005055010_" title="weibo">weibo</a>
					        
								<a class="rss" target="_blank" href="#" title="rss">rss</a>
					        
								<a class="zhihu" target="_blank" href="#" title="zhihu">zhihu</a>
					        
						</div>
					</nav>
				</section>
				
				
				<section class="switch-part switch-part2">
					<div class="widget tagcloud" id="js-tagcloud">
						<a href="/tags/OC/" style="font-size: 10px;">-OC</a> <a href="/tags/Android/" style="font-size: 10px;">Android</a> <a href="/tags/Apple-Watch/" style="font-size: 10px;">Apple Watch</a> <a href="/tags/Flutter/" style="font-size: 13.33px;">Flutter</a> <a href="/tags/Life/" style="font-size: 10px;">Life</a> <a href="/tags/Lottie/" style="font-size: 10px;">Lottie</a> <a href="/tags/MMKV/" style="font-size: 10px;">MMKV</a> <a href="/tags/MonkeyKing/" style="font-size: 10px;">MonkeyKing</a> <a href="/tags/OC/" style="font-size: 20px;">OC</a> <a href="/tags/RAC/" style="font-size: 11.67px;">RAC</a> <a href="/tags/Swift/" style="font-size: 15px;">Swift</a> <a href="/tags/WKWebView/" style="font-size: 10px;">WKWebView</a> <a href="/tags/WebView/" style="font-size: 10px;">WebView</a> <a href="/tags/Xcode/" style="font-size: 18.33px;">Xcode</a> <a href="/tags/appledoc/" style="font-size: 10px;">appledoc</a> <a href="/tags/hexo/" style="font-size: 11.67px;">hexo</a> <a href="/tags/ios/" style="font-size: 10px;">ios</a> <a href="/tags/life/" style="font-size: 16.67px;">life</a> <a href="/tags/xcode/" style="font-size: 10px;">xcode</a>
					</div>
				</section>
				
				
				
				<section class="switch-part switch-part3">
					<div id="js-friends">
					
			          <a target="_blank" class="main-nav-link switch-friends-link" href="http://blog.devtang.com">唐巧的博客</a>
			        
			          <a target="_blank" class="main-nav-link switch-friends-link" href="http://beyondvincent.com">破船之家</a>
			        
			          <a target="_blank" class="main-nav-link switch-friends-link" href="http://limboy.me">无网不剩</a>
			        
			          <a target="_blank" class="main-nav-link switch-friends-link" href="http://msching.github.io">码农人生</a>
			        
			          <a target="_blank" class="main-nav-link switch-friends-link" href="http://yulingtianxia.com">玉令天下</a>
			        
			          <a target="_blank" class="main-nav-link switch-friends-link" href="http://blog.leichunfeng.com">雷纯锋的技术博客</a>
			        
			          <a target="_blank" class="main-nav-link switch-friends-link" href="http://jax.cnblogs.com">包建强</a>
			        
			          <a target="_blank" class="main-nav-link switch-friends-link" href="http://blog.cnbang.net">bang</a>
			        
			        </div>
				</section>
				

				
				
				<section class="switch-part switch-part4">
				
					<div id="js-aboutme">知识管理，时间管理，自我管理，阅读，语音写作，思维导图，Wiz，TimeMeter</div>
				</section>
				
			</div>
		</div>
	</header>				
</div>

    </div>
    <div class="mid-col">
      <nav id="mobile-nav">
  	<div class="overlay">
  		<div class="slider-trigger"></div>
  		<h1 class="header-author js-mobile-header hide">Grx</h1>
  	</div>
	<div class="intrude-less">
		<header id="header" class="inner">
			<div class="profilepic">
			
				<img lazy-src="/img/rufei.jpg" class="js-avatar">
			
			</div>
			<hgroup>
			  <h1 class="header-author">Grx</h1>
			</hgroup>
			
			<p class="header-subtitle">自我管理，知识管理，时间管理，阅读，语音写作，思维导图</p>
			
			<nav class="header-menu">
				<ul>
				
					<li><a href="/">主页</a></li>
		        
					<li><a href="/tags/life">随笔</a></li>
		        
					<li><a href="/archives">所有文章</a></li>
		        
		        <div class="clearfix"></div>
				</ul>
			</nav>
			<nav class="header-nav">
				<div class="social">
					
						<a class="github" target="_blank" href="https://github.com/ruixiaoguo" title="github">github</a>
			        
						<a class="weibo" target="_blank" href="https://weibo.com/u/3984935859?refer_flag=1005055010_" title="weibo">weibo</a>
			        
						<a class="rss" target="_blank" href="#" title="rss">rss</a>
			        
						<a class="zhihu" target="_blank" href="#" title="zhihu">zhihu</a>
			        
				</div>
			</nav>
		</header>				
	</div>
</nav>

      <div class="body-wrap"><article id="post-iOS团队编程规范" class="article article-type-post" itemscope itemprop="blogPost">
  
    <div class="article-meta">
      <a href="/2018/08/15/iOS团队编程规范/" class="article-date">
  	<time datetime="2018-08-15T10:28:47.000Z" itemprop="datePublished">2018-08-15</time>
</a>
    </div>
  
  <div class="article-inner">
    
      <input type="hidden" class="isFancy" />
    
    
      <header class="article-header">
        
  
    <h1 class="article-title" itemprop="name">
      iOS团队编程规范
    </h1>
  

      </header>
      
      <div class="article-info article-info-post">
        
	<div class="article-tag tagcloud">
		<ul class="article-tag-list"><li class="article-tag-list-item"><a class="article-tag-list-link" href="/tags/life/">life</a></li></ul>
	</div>

        

        <div class="clearfix"></div>
      </div>
      
    
    <div class="article-entry" itemprop="articleBody">
      
        <h1 id="iOS团队编程规范"><a href="#iOS团队编程规范" class="headerlink" title="iOS团队编程规范"></a>iOS团队编程规范</h1><p>需求是暂时的，只有变化才是永恒的，面向变化编程，而不是面向需求编程。<br>不要过分追求技巧，降低程序的可读性。<br>简洁的代码可以让bug无处藏身。要写出明显没有bug的代码，而不是没有明显bug的代码。<br>先把眼前的问题解决掉，解决好，再考虑将来的扩展问题。<br><a id="more"></a></p>
<h2 id="一、命名规范"><a href="#一、命名规范" class="headerlink" title="一、命名规范"></a>一、命名规范</h2><h2 id="1、统一要求"><a href="#1、统一要求" class="headerlink" title="1、统一要求"></a>1、统一要求</h2><p>含义清楚，尽量做到不需要注释也能了解其作用，若做不到，就加注释，使用全称，不使用缩写。</p>
<h2 id="2、类名"><a href="#2、类名" class="headerlink" title="2、类名"></a>2、类名</h2><p>大驼峰式命名：每个单词的首字母都采用大写字母</p>
<pre><code>==例：==MFHomePageViewController
</code></pre><h2 id="3、私有变量"><a href="#3、私有变量" class="headerlink" title="3、私有变量"></a>3、私有变量</h2><p>• 私有变量放在 .m 文件中声明<br>• 以 _ 开头，第一个单词首字母小写，后面的单词的首字母全部大写。</p>
<pre><code>==例：==NSString *_somePrivateVariable
</code></pre><h2 id="4、property变量"><a href="#4、property变量" class="headerlink" title="4、property变量"></a>4、property变量</h2><p>• 小驼峰式命名：第一个单词以小写字母开始，后面的单词的首字母全部大写<br>• 属性的关键字推荐按照 原子性，读写，内存管理的顺序排列。<br>• Block、NSString属性应该使用copy关键字<br>• 禁止使用synthesize关键词<br>==例：==</p>
<pre><code>typedefvoid(^ErrorCodeBlock) (iderrorCode,NSString*message);
@property(nonatomic,readwrite,strong)UIView*headerView;   //注释
@property(nonatomic,readwrite,copy) ErrorCodeBlock errorBlock;  //将block拷贝到堆中
@property(nonatomic,readwrite,copy)NSString*userName;   
</code></pre><h2 id="5、宏和常量命名"><a href="#5、宏和常量命名" class="headerlink" title="5、宏和常量命名"></a>5、宏和常量命名</h2><p>• 对于宏定义的常量<br>◦ #define预处理定义的常量全部大写，单词间用 _ 分隔<br>◦ 宏定义中如果包含表达式或变量，表达式或变量必须用小括号括起来。<br>• 对于类型常量<br>◦ 对于局限于某编译单元(实现文件)的常量，以字符k开头，例如kAnimationDuration，且需要以static const修饰<br>◦ 对于定义于类头文件的常量，外部可见，则以定义该常量所在类的类名开头，例如EOCViewClassAnimationDuration, 仿照苹果风格，在头文件中进行extern声明，在实现文件中定义其值<br>==例：==</p>
<pre><code>//宏定义的常量
#define ANIMATION_DURATION    0.3
#define MY_MIN(A, B)  ((A)&gt;(B)?(B):(A))
//局部类型常量
staticconstNSTimeIntervalkAnimationDuration =0.3;
//外部可见类型常量
//EOCViewClass.h
externconstNSTimeIntervalEOCViewClassAnimationDuration;
externNSString*constEOCViewClassStringConstant; //字符串类型
//EOCViewClass.m
constNSTimeIntervalEOCViewClassAnimationDuration =0.3;
NSString*constEOCViewClassStringConstant =@&quot;EOCStringConstant&quot;;
</code></pre><h2 id="6、Enum"><a href="#6、Enum" class="headerlink" title="6、Enum"></a>6、Enum</h2><p>• Enum类型的命名与类的命名规则一致<br>• Enum中枚举内容的命名需要以该Enum类型名称开头<br>• NS_ENUM定义通用枚举，NS_OPTIONS定义位移枚举<br>==例：==</p>
<pre><code>typedefNS_ENUM(NSInteger,UIViewAnimationTransition) {
UIViewAnimationTransitionNone,
UIViewAnimationTransitionFlipFromLeft,
UIViewAnimationTransitionFlipFromRight,
UIViewAnimationTransitionCurlUp,
UIViewAnimationTransitionCurlDown,
};
typedefNS_OPTIONS(NSUInteger,UIControlState) {
UIControlStateNormal      =0,
UIControlStateHighlighted  =1&lt;&lt;0,
UIControlStateDisabled    =1&lt;&lt;1,
};
</code></pre><h2 id="7、Delegate"><a href="#7、Delegate" class="headerlink" title="7、Delegate"></a>7、Delegate</h2><p>• 用delegate做后缀，如<uiscrollviewdelegate><br>• 用optional修饰可以不实现的方法，用required修饰必须实现的方法<br>• 当你的委托的方法过多, 可以拆分数据部分和其他逻辑部分, 数据部分用dataSource做后缀. 如<uitableviewdatasource><br>• 使用did和will通知Delegate已经发生的变化或将要发生的变化。<br>• 类的实例必须为回调方法的参数之一<br>1 回调方法的参数只有类自己的情况，方法名要符合实际含义<br>2 回调方法存在两个以上参数的情况，以类的名字开头，以表明此方法是属于哪个类的<br>==例：==</uitableviewdatasource></uiscrollviewdelegate></p>
<pre><code>@protocolUITableViewDataSource&lt;NSObject &gt;
@required
//回调方法存在两个以上参数
- (NSInteger)tableView:(UITableView*)tableView numberOfRowsInSection:(NSInteger)section;
@optional
//回调方法的参数只有类自己
- (NSInteger)numberOfSectionsInTableView:(UITableView*)tableView;             // Default is 1 if not implemented
@protocolUITableViewDelegate&lt;NSObject,UIScrollViewDelegate &gt;
@optional
//使用`did`和`will`通知`Delegate`
- (nullableNSIndexPath*)tableView:(UITableView*)tableView willSelectRowAtIndexPath:(NSIndexPath*)indexPath;
- (void)tableView:(UITableView*)tableView didSelectRowAtIndexPath:(NSIndexPath*)indexPath;
</code></pre><h2 id="8、方法"><a href="#8、方法" class="headerlink" title="8、方法"></a>8、方法</h2><p>• 方法名用小驼峰式命名<br>• 方法名不要使用new作为前缀<br>• 不要使用and来连接属性参数，如果方法描述两种独立的行为，使用and来串接它们。<br>• 方法实现时，如果参数过长，则令每个参数占用一行，以冒号对齐。<br>• 一般方法不使用前缀命名，私有方法可以使用统一的前缀来分组和辨识<br>• 方法名要与对应的参数名保持高度一致<br>• 表示对象行为的方法、执行性的方法应该以动词开头<br>• 返回性的方法应该以返回的内容开头，但之前不要加get，除非是间接返回一个或多个值。<br>• 可以使用情态动词(动词前面can、should、will等)进一步说明属性意思，但不要使用do或does,因为这些助动词没什么实际意义。也不要在动词前使用副词或形容词修饰<br>==例：==</p>
<pre><code>//不要使用 and 来连接属性参数
- (int)runModalForDirectory:(NSString*)path file:(NSString*)name types:(NSArray*)fileTypes;   //推荐
- (int)runModalForDirectory:(NSString*)path andFile:(NSString*)name andTypes:(NSArray*)fileTypes;   //反对
//表示对象行为的方法、执行性的方法
- (void)insertModel:(id)model atIndex:(NSUInteger)atIndex;
- (void)selectTabViewItem:(NSTableViewItem*)tableViewItem
//返回性的方法
- (instancetype)arrayWithArray:(NSArray*)array;
//参数过长的情况
- (void)longMethodWith:(NSString*)theFoo
rect:(CGRect)theRect
interval:(CGFloat)theInterval
{
//Implementation
}
//不要加get
- (NSSize) cellSize; //推荐
- (NSSize) getCellSize; //反对
//使用情态动词,不要使用do或does
- (BOOL)canHide; //推荐
- (BOOL)shouldCloseDocument; //推荐
- (BOOL)doesAcceptGlyphInfo; //反对
</code></pre><h2 id="二、代码注释规范"><a href="#二、代码注释规范" class="headerlink" title="二、代码注释规范"></a>二、代码注释规范</h2><p>优秀的代码大部分是可以自描述的，我们完全可以用代码本身来表达它到底在干什么，而不需要注释的辅助。<br>但并不是说一定不能写注释，有以下三种情况比较适合写注释：<br>• 公共接口（注释要告诉阅读代码的人，当前类能实现什么功能）。<br>• 涉及到比较深层专业知识的代码（注释要体现出实现原理和思想）。<br>• 容易产生歧义的代码（但是严格来说，容易让人产生歧义的代码是不允许存在的）。<br>除了上述这三种情况，如果别人只能依靠注释才能读懂你的代码的时候，就要反思代码出现了什么问题。<br>最后，对于注释的内容，相对于“做了什么”，更应该说明“为什么这么做”。</p>
<h2 id="1、import注释"><a href="#1、import注释" class="headerlink" title="1、import注释"></a>1、import注释</h2><p>如果有一个以上的import语句，就对这些语句进行分组，每个分组的注释是可选的。</p>
<pre><code>// Frameworks
#import&lt;QuartzCore&gt;;
// Models
#import&quot;NYTUser.h&quot;
// Views
#import&quot;NYTButton.h&quot;
#import&quot;NYTUserView.h&quot;
</code></pre><h2 id="2、属性注释"><a href="#2、属性注释" class="headerlink" title="2、属性注释"></a>2、属性注释</h2><p>写在属性之后，用两个空格隔开<br>==例：==</p>
<pre><code>@property(nonatomic,readwrite,strong)UIView*headerView; //注释   
</code></pre><h2 id="3、方法声明注释："><a href="#3、方法声明注释：" class="headerlink" title="3、方法声明注释："></a>3、方法声明注释：</h2><p>一个函数(方法)必须有一个字符串文档来解释，除非它：<br>• 非公开，私有函数。<br>• 很短。<br>• 显而易见。<br>而其余的，包括公开接口，重要的方法，分类，以及协议，都应该伴随文档（注释）：<br>• 以/开始<br>• 第二行是总结性的语句<br>• 第三行永远是空行<br>• 在与第二行开头对齐的位置写剩下的注释。<br>建议这样写：</p>
<pre><code>/This comment serves to demonstrate the format of a docstring.
Note that the summary line is always at most one linelong,andafter the opening block comment,
andeach line of text is preceded by a single space.
*/
</code></pre><p>方法的注释使用Xcode自带注释快捷键:Commond+option+/<br>==例：==</p>
<pre><code>/**
&lt;#Description#&gt;
@param tableView &lt;#tableView description#&gt;
@param section &lt;#section description#&gt;
@return&lt;#return value description#&gt;
*/
- (CGFloat)tableView:(UITableView *)tableView heightForHeaderInSection:(NSInteger)section
{
//...
}
</code></pre><h2 id="4、代码块注释"><a href="#4、代码块注释" class="headerlink" title="4、代码块注释"></a>4、代码块注释</h2><p>单行的用//+空格开头，多行的采用/<em> </em>/注释</p>
<h2 id="5、TODO"><a href="#5、TODO" class="headerlink" title="5、TODO"></a>5、TODO</h2><p>使用//TODO:说明标记一些未完成的或完成的不尽如人意的地方<br>==例：==</p>
<pre><code>- (BOOL)application:(UIApplication*)application didFinishLaunchingWithOptions:(NSDictionary*)launchOptions
{
//TODO:增加初始化
returnYES;
}
</code></pre><h2 id="三、代码格式化规范"><a href="#三、代码格式化规范" class="headerlink" title="三、代码格式化规范"></a>三、代码格式化规范</h2><h2 id="1、指针-位置"><a href="#1、指针-位置" class="headerlink" title="1、指针*位置"></a>1、指针*位置</h2><p>定义一个对象时，指针*靠近变量</p>
<pre><code>==例:==NSString *userName;
</code></pre><h2 id="2、方法的声明和定义"><a href="#2、方法的声明和定义" class="headerlink" title="2、方法的声明和定义"></a>2、方法的声明和定义</h2><p>在- 、+和 返回值之间留一个空格，方法名和第一个参数之间不留空格<br>==例：==</p>
<pre><code>- (void)insertSubview:(UIView*)view atIndex:(NSInteger)index;
</code></pre><h2 id="3、代码缩进"><a href="#3、代码缩进" class="headerlink" title="3、代码缩进"></a>3、代码缩进</h2><p>• 不要在工程里使用 Tab 键，使用空格来进行缩进。在 Xcode &gt; Preferences &gt; Text Editing 将 Tab 和自动缩进都设置为 4 个空格<br>• Method与Method之间空一行<br>• 一元运算符与变量之间没有空格、二元运算符与变量之间必须有空格<br>==例：==</p>
<pre><code>!bValue
fLength = fWidth *2;
- (void)sampleMethod1;
- (void)sampleMethod2;
</code></pre><h2 id="4、对method进行分组"><a href="#4、对method进行分组" class="headerlink" title="4、对method进行分组"></a>4、对method进行分组</h2><p>使用#pragma mark -对method进行分组</p>
<pre><code>#pragma mark - Life Cycle Methods
- (instancetype)init
- (void)dealloc
- (void)viewWillAppear:(BOOL)animated
- (void)viewDidAppear:(BOOL)animated
- (void)viewWillDisappear:(BOOL)animated
- (void)viewDidDisappear:(BOOL)animated
#pragma mark - Override Methods
#pragma mark - Intial Methods
#pragma mark - Network Methods
#pragma mark - Target Methods
#pragma mark - Public Methods
#pragma mark - Private Methods
#pragma mark - UITableViewDataSource 
#pragma mark - UITableViewDelegate 
#pragma mark - Lazy Loads
#pragma mark - NSCopying 
#pragma mark - NSObject  Methods
</code></pre><h2 id="5、大括号写法"><a href="#5、大括号写法" class="headerlink" title="5、大括号写法"></a>5、大括号写法</h2><p>• 对于类的method:左括号另起一行写(遵循苹果官方文档)<br>• 对于其他使用场景(if,for,while,switch等): 左括号跟在第一行后边<br>==例：==</p>
<pre><code>- (void)sampleMethod
{
BOOLsomeCondition =YES;
if(someCondition) {
// do something here
}
}
</code></pre><h2 id="6、property变量"><a href="#6、property变量" class="headerlink" title="6、property变量"></a>6、property变量</h2><p>==例：==</p>
<pre><code>@property(nonatomic,readwrite,strong)UIView*headerView;   //注释   
</code></pre><h2 id="四、编码规范"><a href="#四、编码规范" class="headerlink" title="四、编码规范"></a>四、编码规范</h2><h2 id="1、if语句"><a href="#1、if语句" class="headerlink" title="1、if语句"></a>1、if语句</h2><p>①、须列出所有分支（穷举所有的情况），而且每个分支都须给出明确的结果。</p>
<pre><code>==推荐这样写：==
varhintStr;
if(count &lt;3) {
hintStr =&quot;Good&quot;;
}else{
hintStr =&quot;&quot;;
}
==不推荐这样写：==
varhintStr;
if(count &lt;3) {
hintStr =&quot;Good&quot;;
}
</code></pre><p>②、不要使用过多的分支，要善于使用return来提前返回错误的情况，把最正确的情况放到最后返回。</p>
<pre><code>==推荐这样写：==
if(!user.UserName)returnNO;
if(!user.Password)returnNO;
if(!user.Email)returnNO;
returnYES;
==不推荐这样写：==
BOOLisValid =NO;
if(user.UserName)
{
if(user.Password)
{
if(user.Email) isValid =YES;
}
}
returnisValid;
</code></pre><p>③、条件过多，过长的时候应该换行。条件表达式如果很长，则需要将他们提取出来赋给一个BOOL值，或者抽取出一个方法</p>
<pre><code>==推荐这样写：==
if(condition1 &amp;&amp;
condition2 &amp;&amp;
condition3 &amp;&amp;
condition4) {
// Do something
}
BOOLfinalCondition = condition1 &amp;&amp; condition2 &amp;&amp; condition3 &amp;&amp; condition4
if(finalCondition) {
// Do something
}
if([selfcanDelete]){
// Do something
}
- (BOOL)canDelete
{
BOOLfinalCondition1 = condition1 &amp;&amp; condition2
BOOLfinalCondition2 =  condition3 &amp;&amp; condition4
returncondition1 &amp;&amp; condition2;
}
==不推荐这样写：==
if(condition1 &amp;&amp; condition2 &amp;&amp; condition3 &amp;&amp; condition4) {
// Do something
}
</code></pre><p>④、条件语句的判断应该是变量在右，常量在左。</p>
<pre><code>==推荐：==
if(6== count) {
}
if(nil== object) {
}
if(!object) {
}
==不推荐：==
if(count ==6) {
}
if(object ==nil) {
}
if (object == nil)容易误写成赋值语句,if (!object)写法很简洁
</code></pre><p>⑤、每个分支的实现代码都须被大括号包围</p>
<pre><code>==推荐：==
if(!error) {
returnsuccess;
}
==不推荐：==
if(!error)
returnsuccess;
可以如下这样写：
if(!error)returnsuccess;
</code></pre><h2 id="2、for语句"><a href="#2、for语句" class="headerlink" title="2、for语句"></a>2、for语句</h2><p>①、不可在for循环内修改循环变量，防止for循环失去控制。</p>
<pre><code>for(intindex =0; index &lt;10; index++){
...
logicToChange(index)
}
</code></pre><p>②、避免使用continue和break。<br>continue和break所描述的是“什么时候不做什么”，所以为了读懂二者所在的代码，我们需要在头脑里将他们取反。<br>其实最好不要让这两个东西出现，因为我们的代码只要体现出“什么时候做什么”就好了，而且通过适当的方法，是可以将这两个东西消灭掉的：</p>
<pre><code>• 如果出现了continue，只需要把continue的条件取反即可
varfilteredProducts =Array&lt;String&gt;()
forlevelinproducts {
iflevel.hasPrefix(&quot;bad&quot;) {
continue
}
filteredProducts.append(level)
}
我们可以看到，通过判断字符串里是否含有“bad”这个prefix来过滤掉一些值。其实我们是可以通过取反，来避免使用continue的：
forlevelinproducts {
if!level.hasPrefix(&quot;bad&quot;) {
filteredProducts.append(level)
}
}
• 消除while里的break：将break的条件取反，并合并到主循环里
在while里的break其实就相当于“不存在”，既然是不存在的东西就完全可以在最开始的条件语句中将其排除。
while里的break：
while(condition1) {
...
if(condition2) {
break;
}
}
取反并合并到主条件：
while(condition1 &amp;&amp; !condition2) {
...
}
• 在有返回值的方法里消除break：将break转换为return立即返回
有人喜欢这样做：在有返回值的方法里break之后，再返回某个值。其实完全可以在break的那一行直接返回。
func hasBadProductIn(products:Array&lt;String&gt;) -&gt; Bool {
varresult =false   
forlevelinproducts {
iflevel.hasPrefix(&quot;bad&quot;) {
result =true
break
}
}
returnresult
}
遇到错误条件直接返回：
func hasBadProductIn(products:Array&lt;String&gt;) -&gt; Bool {
forlevelinproducts {
iflevel.hasPrefix(&quot;bad&quot;) {
returntrue
}
}
returnfalse
}
</code></pre><p>这样写的话不用特意声明一个变量来特意保存需要返回的值，看起来非常简洁，可读性高。</p>
<h2 id="3、Switch语句"><a href="#3、Switch语句" class="headerlink" title="3、Switch语句"></a>3、Switch语句</h2><p>①、每个分支都必须用大括号括起来<br>推荐这样写：</p>
<pre><code>switch(integer) { 
case1:  {
// ... 
}
break; 
case2: { 
// ... 
break; 
} 
default:{
// ... 
break;
}
}
</code></pre><p>②、使用枚举类型时，不能有default分支， 除了使用枚举类型以外，都必须有default分支</p>
<pre><code>RWTLeftMenuTopItemType menuType = RWTLeftMenuTopItemMain; 
switch(menuType) { 
caseRWTLeftMenuTopItemMain: {
// ... 
break;
}
caseRWTLeftMenuTopItemShows: {
// ... 
break;
}
caseRWTLeftMenuTopItemSchedule: {
// ... 
break;
}
}
</code></pre><p>在Switch语句使用枚举类型的时候，如果使用了default分支，在将来就无法通过编译器来检查新增的枚举类型了。</p>
<h2 id="4、函数"><a href="#4、函数" class="headerlink" title="4、函数"></a>4、函数</h2><p>①、一个函数只做一件事（单一原则）<br>每个函数的职责都应该划分的很明确（就像类一样）。</p>
<pre><code>==推荐：==
dataConfiguration()
viewConfiguration()
==不推荐：==
voiddataConfiguration()
{  
...
viewConfiguration()
}
</code></pre><p>②、对于有返回值的函数（方法），每一个分支都必须有返回值</p>
<pre><code>==推荐：==
intfunction()
{
if(condition1){
returncount1
}elseif(condition2){
returncount2
}else{
returndefaultCount
}
}
==不推荐：==
intfunction()
{
if(condition1){
returncount1
}elseif(condition2){
returncount2
}
}
</code></pre><p>③、对输入参数的正确性和有效性进行检查，参数错误立即返回</p>
<pre><code>==推荐：==
voidfunction(param1,param2)
{
if(param1 is unavailable){
return;
}
if(param2 is unavailable){
return;
}
//Do some right thing
}
</code></pre><p>④、如果在不同的函数内部有相同的功能，应该把相同的功能抽取出来单独作为另一个函数<br>原来的调用：</p>
<pre><code>voidlogic() {
a();
b()；
if(logic1 condition) {
c();
}else{
d();
}
}
将a，b函数抽取出来作为单独的函数
voidbasicConfig() {
a();
b();
}
voidlogic1() {
basicConfig();
c();
}
voidlogic2() {
basicConfig();
d();
}
</code></pre><p>⑤、将函数内部比较复杂的逻辑提取出来作为单独的函数<br>一个函数内的不清晰（逻辑判断比较多，行数较多）的那片代码，往往可以被提取出去，构成一个新的函数，然后在原来的地方调用它这样你就可以使用有意义的函数名来代替注释，增加程序的可读性。<br>举一个发送邮件的例子：</p>
<pre><code>openEmailSite();
login();
writeTitle(title);
writeContent(content);
writeReceiver(receiver);
addAttachment(attachment);
send();
中间的部分稍微长一些，我们可以将它们提取出来：
voidwriteEmail(title, content,receiver,attachment)
{
writeTitle(title);
writeContent(content);
writeReceiver(receiver);
addAttachment(attachment);
}
</code></pre><p>然后再看一下原来的代码：</p>
<pre><code>openEmailSite();
login();
writeEmail(title, content,receiver,attachment)
send();
</code></pre>
      
    </div>
    
  </div>
  
    
<nav id="article-nav">
  
    <a href="/2018/08/15/iOS应用架构谈 view层的组织和调用方案/" id="article-nav-newer" class="article-nav-link-wrap">
      <strong class="article-nav-caption"><</strong>
      <div class="article-nav-title">
        
          iOS应用架构谈 view层的组织和调用方案
        
      </div>
    </a>
  
  
    <a href="/2018/07/18/iOS应用架构谈 开篇/" id="article-nav-older" class="article-nav-link-wrap">
      <div class="article-nav-title">iOS应用架构谈 开篇</div>
      <strong class="article-nav-caption">></strong>
    </a>
  
</nav>

  
</article>


<div class="share_jia">
	<!-- JiaThis Button BEGIN -->
	<div class="jiathis_style">
		<span class="jiathis_txt">Share to: &nbsp; </span>
		<a class="jiathis_button_facebook"></a> 
    <a class="jiathis_button_twitter"></a>
    <a class="jiathis_button_plus"></a> 
    <a class="jiathis_button_tsina"></a>
		<a class="jiathis_button_cqq"></a>
		<a class="jiathis_button_douban"></a>
		<a class="jiathis_button_weixin"></a>
		<a class="jiathis_button_tumblr"></a>
    <a href="http://www.jiathis.com/share" class="jiathis jiathis_txt jtico jtico_jiathis" target="_blank"></a>
	</div>
	<script type="text/javascript" src="http://v3.jiathis.com/code/jia.js?uid=1405949716054953" charset="utf-8"></script>
	<!-- JiaThis Button END -->
</div>






<div class="duoshuo">
	<!-- 多说评论框 start -->
	<div class="ds-thread" data-thread-key="iOS团队编程规范" data-title="iOS团队编程规范" data-url="http://yoursite.com/2018/08/15/iOS团队编程规范/"></div>
	<!-- 多说评论框 end -->
	<!-- 多说公共JS代码 start (一个网页只需插入一次) -->
	<script type="text/javascript">
	var duoshuoQuery = {short_name:"true"};
	(function() {
		var ds = document.createElement('script');
		ds.type = 'text/javascript';ds.async = true;
		ds.src = (document.location.protocol == 'https:' ? 'https:' : 'http:') + '//static.duoshuo.com/embed.js';
		ds.charset = 'UTF-8';
		(document.getElementsByTagName('head')[0] 
		 || document.getElementsByTagName('body')[0]).appendChild(ds);
	})();
	</script>
	<!-- 多说公共JS代码 end -->
</div>




</div>
      <footer id="footer">
  <div class="outer">
    <div id="footer-info">
    	<div class="footer-left">
    		&copy; 2019 Grx
    	</div>
      	<div class="footer-right">
      		<a href="http://hexo.io/" target="_blank">Hexo</a>  Theme <a href="https://github.com/litten/hexo-theme-yilia" target="_blank">Yilia</a> by Litten
      	</div>
    </div>
  </div>
</footer>
    </div>
    
  <link rel="stylesheet" href="/fancybox/jquery.fancybox.css">


<script>
	var yiliaConfig = {
		fancybox: true,
		mathjax: true,
		animate: true,
		isHome: false,
		isPost: true,
		isArchive: false,
		isTag: false,
		isCategory: false,
		open_in_new: false
	}
</script>
<script src="http://7.url.cn/edu/jslib/comb/require-2.1.6,jquery-1.9.1.min.js"></script>
<script src="/js/main.js"></script>






<script type="text/x-mathjax-config">
MathJax.Hub.Config({
    tex2jax: {
        inlineMath: [ ['$','$'], ["\\(","\\)"]  ],
        processEscapes: true,
        skipTags: ['script', 'noscript', 'style', 'textarea', 'pre', 'code']
    }
});

MathJax.Hub.Queue(function() {
    var all = MathJax.Hub.getAllJax(), i;
    for(i=0; i < all.length; i += 1) {
        all[i].SourceElement().parentNode.className += ' has-jax';                 
    }       
});
</script>

<script type="text/javascript" src="http://cdn.mathjax.org/mathjax/latest/MathJax.js?config=TeX-AMS-MML_HTMLorMML">
</script>


  </div>
</body>
</html>